package com.xuwang.mapper;

import com.xuwang.pojo.Stock;
import com.xuwang.vo.StockListReturnVO;
import org.apache.ibatis.annotations.Param;
import java.util.List;

/**
 * 进货表（菜品、原料、添加剂都在这里面）(Stock)表数据库访问层
 *
 * @author abaaba
 * @since 2021-09-18 14:18:01
 * @version 1.0
 */
public interface StockMapper {

    /**
     * 查询所有数据
     * @return  返回所有数据
     */
    List<Stock> selectAll();

    /**
     * 通过ID查询单条数据
     *
     * @param id 主键
     * @return 实例对象
     */
    Stock selectById(@Param("id") Integer id);
    String selectBatchNoById(@Param("id") Integer id);

    /**
     * 根据模糊条件查询总个数
     *
     * @return 返回查询到的总个数
     */
    int selectForCount(@Param("m")   int m,
                       @Param("name")   String name,
                       @Param("batchNo")   String batchNo,
                       @Param("type") String type,
                       @Param("starTime") String starTime,
                       @Param("endTime")   String endTime,
                       @Param("warranty")     Integer warranty,
                       @Param("supplyCompanyName")     String supplyCompanyName,
                       @Param("receiveCompanyName")    String receiveCompanyName);

    /**
     * 通过实体作为筛选条件查询
     * 
     * @param index 查询起始位置
//     * @param name  查询条件
     * @return 对象列表
     */
    List<StockListReturnVO> selectForPage(@Param("m")   int m,
                                          @Param("index") int index,
                                          @Param("page")int page,
                                          @Param("name")   String name,
                                          @Param("batchNo")   String batchNo,
                                          @Param("type") String type,
                                          @Param("starTime") String starTime,
                                          @Param("endTime")   String endTime,
                                          @Param("warranty")     Integer warranty,
                                          @Param("supplyCompanyName")     String supplyCompanyName,
                                          @Param("receiveCompanyName")    String receiveCompanyName);

    /**
     * 新增数据
     *
     * @param stock 实例对象
     */
    void insert(Stock stock);

    /**
     * 修改数据
     *
     * @param stock 实例对象
     * @return 影响行数
     */
    int updateById(Stock stock);

    /**
     * 通过主键删除数据
     *
     * @param id 主键
     * @return 影响行数
     */
    int deleteById(@Param("id") String id);

}